操作系统之——银行家算法C语言实现

// 银行家算法.cpp : 定义控制台应用程序的入口点。
//

#include "stdafx.h"
#include "string.h"
#include "stdlib.h"

#define MAX_PROCESS 10 //进程数上限
#define MAX_RESOURCE_KIND 10 //资源种类上限
#define MAX_RESOURCE_NUM 20	//每种资源可用数上限

int resource;	//实际资源种类数
int process;	//实际进程数
int safe_list[MAX_PROCESS];	//安全序列

struct AVAILABLE {	//可用资源向量
	int resource_number; //资源数目
	int work;	//工作向量	
}Resource[MAX_RESOURCE_KIND], R_backup[MAX_RESOURCE_KIND];

struct PROC {	//进程数据向量表
	int max[MAX_RESOURCE_KIND];	//最大需求矩阵
	int allocation[MAX_RESOURCE_KIND];	//分配矩阵
	int need[MAX_RESOURCE_KIND];	//需求矩阵
	bool finish;	//满足标记
}Process[MAX_PROCESS], P_backup[MAX_PROCESS];

void zero();
void show_me();
void init();
void init_allocation();
void update();
void backup();
void re_backup();
bool allocation();
bool one_allocation(int a, int b, int c);
bool release();
bool one_release(int a, int b, int c);
int is_safe();
void test();
int banker();
void menu();

void zero() {//清零
	for (int i = 0; i<MAX_RESOURCE_KIND; i++) {
		Resource[i].resource_number = 0;
	}
	for (int i = 0; i<MAX_RESOURCE_KIND; i++) {
		for (int j = 0; j< MAX_RESOURCE_KIND; j++) {
			Process[i].max[j] = 0;
			Process[i].allocation[j] = 0;
			Process[i].need[j] = 0;
		}
	}
}


void show_me() {//绘制矩阵
	printf("\n  Available矩阵  ");
	for (int i = 0; i < resource; i++) {
		printf("%d ", Resource[i].resource_number);
	}
	printf("\n");
	printf("\n  Max矩阵");
	for (int i = 0; i < MAX_RESOURCE_KIND *2-7; i++) printf(" ");
	printf("Allocation矩阵");
	for (int i = 0; i < MAX_RESOURCE_KIND * 2 -14; i++) printf(" ");
	printf("Need矩阵");
	for (int i = 0; i < MAX_RESOURCE_KIND * 2 - 8; i++) printf(" ");

	for (int i = 0; i<process; i++) {
		printf("\n  ");
		for (int j = 0; j<resource; j++) printf("%d ", Process[i].max[j]);
		for (int i = 0; i < MAX_RESOURCE_KIND * 2 - resource*2; i++) printf(" ");
		for (int j = 0; j<resource; j++)	printf("%d ", Process[i].allocation[j]);
		for (int i = 0; i < MAX_RESOURCE_KIND * 2 - resource * 2; i++) printf(" ");
		for (int j = 0; j<resource; j++) printf("%d ", Process[i].need[j]);	
	}
	printf("\n");	
}


void init() {//初始化
	int n;
	printf("\n输入资源种类数  ");
	scanf("%d", &n);
	resource = n;
	for (int i = 0; i<resource; i++) {
		printf("\n输入第%d种资源数量  ", i + 1);
		scanf("%d", &n);
		Resource[i].resource_number = n;
	}
	printf("\n输入进程数  ");
	scanf("%d", &n);
	process = n;
	for (int i = 0; i<process; i++) {
		int a, flag;
		flag = 0;
		printf("\n输入进程%d种资源使用数目  ", i + 1);
		for (int j = 0; j<resource; j++) {
			scanf("%d", &a);
			Process[i].max[j] = a;
			if (a>Resource[j].resource_number) flag = 1;
		}
		if (flag == 1) {
			i--;
			printf("\n需求超过资源上限请重新输入\n");
		}
		getchar();
	}
}

void init_allocation() {//初始分配状态
	for (int i = 0; i<process; i++) {
		int a, flag;
		flag = 0;
		printf("\n输入进程%d当前资源占用情况  ", i + 1);
		for (int j = 0; j<resource; j++) {
			scanf("%d", &a);
			Process[i].allocation[j] = a;
			if (a>Resource[j].resource_number) flag = 1;
		}
		if (flag == 1) {
			i--;
			printf("\n当前资源占用超过资源上限请重新输入\n");
		}
	}
	update();
}


void update() {//更新需求矩阵need和资源向量allocation
	for (int i = 0; i<process; i++) {
		for (int j = 0; j<resource; j++) {
			Process[i].need[j] = Process[i].max[j] - Process[i].allocation[j];
			Resource[j].resource_number -= Process[i].allocation[j];
		}
	}
}
bool allocation() {
	backup();
	printf("\n请输入 进程号以及对应资源所分配的数目用空格隔开\n");
	int pro_num;
	scanf("%d", &pro_num);
	int aff[MAX_RESOURCE_KIND];
	for (int i = 0; i < resource; i++) {
		scanf("%d", &aff[i]);
	}
	for (int i = 0; i < resource; i++) {
		if (one_allocation(pro_num-1, i, aff[i]) == false) {//调用单次分配函数尝试分配
			re_backup();
			return false;
		}
	}
	return true;
}

bool one_allocation(int a, int b, int c) {//单次分配
	if (c>Process[a].need[b]) {
		printf("要求超过所需上限,请求失败\n");
		return false;
	}
	else if (c>Resource[b].resource_number) {
		printf("无足够资源,请求失败\n");
		return false;
	}
	Resource[b].resource_number -= c;
	Process[a].need[b] -= c;
	Process[a].allocation[b] += c;
	return true;
}
void backup() {		//数据备份
	for (int i = 0; i < process; i++) {
		P_backup[i] = Process[i];
	}
	for (int i = 0; i < resource; i++) {
		R_backup[i] = Resource[i];
	}
}
void re_backup() {	//数据还原
	for (int i = 0; i < process; i++) {
		Process[i] = P_backup[i];
	}
	for (int i = 0; i < resource; i++) {
		Resource[i] = R_backup[i];
	}
}
bool release() {	//释放资源
	backup();
	printf("\n请输入 进程号以及对应资源所分配的数目用空格隔开\n");
	int pro_num;
	scanf("%d", &pro_num);
	int aff[MAX_RESOURCE_KIND];
	for (int i = 0; i < resource; i++) {
		scanf("%d", &aff[i]);
	}
	for (int i = 0; i < resource; i++) {
		if (one_release(pro_num, i, aff[i]) == false) {
			re_backup();
			return false;
		}
	}
	return true;
}
bool one_release(int a, int b, int c) {//资源释放
	if (c>Process[a].allocation[b]) {
		printf("释放超过所有上限,请求失败\n");
		return false;
	}
	Resource[b].resource_number += c;
	Process[a].need[b] += c;
	Process[a].allocation[b] -= c;
	return true;
}

int is_safe() {	//安全性检测算法

	for (int i = 0; i < resource; i++) {
		Resource[i].work = Resource[i].resource_number;
	}
	for (int i = 0; i < process; i++) {
		Process[i].finish = false;
		safe_list[i] = 0;
	}
	test();
	bool flag = true;
	for (int i = 0; i < process; i++) {
		if (Process[i].finish == false) {
			flag = false;
			break;
		}
	}
	if (flag == true) {
		printf("\n系统状态安全");
		printf("\n安全序列为  ");
		for (int i = 0; i < process; i++) {
			printf("%d ",safe_list[i]);
		}
		return 1;
	}
	else {
		printf("\n系统状态不安全");
		return -1;
	}
}


void test() {	//安全性算法的递归分支
	for (int i = 0; i < process; i++) {
		bool flag=true;
		if (Process[i].finish == false) {
			for (int j = 0; j < resource; j++) {
				if (Process[i].need[j] > Resource[j].work) {
					flag = false;
					break;
				}
			}
			if (flag == true) {
				for (int j = 0; j < resource; j++) {
					Resource[j].work += Process[i].allocation[j];
					Process[i].finish = true;
				}
				for (int k = 0; k < process; k++) {
					if (safe_list[k] == 0) {
						safe_list[k] = i + 1;
						break;
					}
				}
				test();	//递归处理
			}
		}
	}
}


int banker() {//银行家算法
	backup();	//备份
	if (allocation() == false) return -1;
	bool flag;
	flag = is_safe();
	if (flag == true) {
		char k;
		printf("\n是否分配(y/n)  ");
		scanf("%c",&k);
		if (k == 'y') return 1;
		else {
			re_backup();
			return -1;
		}
	}
	else {
		re_backup();
		return -1;
	}
}
void menu() {	//菜单函数
	printf("\n请输入指令\n");
	printf("\n初始化(init) 显示数据矩阵(show) 判断安全性(safe)\n申请资源(request) 释放资源(release) 退出(quit)\n清屏(clear)\n");
	char code[20];
	while (1) {
		printf("\n");
		scanf("%s", code);
		if (_stricmp(code, "init") == 0) {	//重置操作
			zero();
			init();
			init_allocation();
		}
		else if (_stricmp(code, "show") == 0) {	//显示功能
			show_me();
		}
		else if (_stricmp(code, "safe") == 0) {	//判断安全性
			is_safe();
		}
		else if (_stricmp(code, "request") == 0) {	//申请资源
			printf("\n是否使用银行家算法保证安全性(y/n)\n");
			scanf("%s", code);
			if (_stricmp(code, "y") == 0) banker();
			else allocation();
		}
		else if (_stricmp(code, "release") == 0) {	//释放资源
			release();
		}
		else if (_stricmp(code, "quit") == 0) {	//退出
			return;
		}
		else if (_stricmp(code, "clear") == 0) {	//清屏
			system("cls");
			printf("\n请输入指令\n");
			printf("\n初始化(init) 显示数据矩阵(show) 判断安全性(safe)\n申请资源(request) 释放资源(release) 退出(quit)\n清屏(clear)\n");
		}
		else printf("命令无效,请重新输入\n");
	}
}

int _tmain(int argc, _TCHAR* argv[])
{
	/*
	zero();
	init();
	init_allocation();
	show_me();
	is_safe();*/
	menu();
	getchar();
	return 0;
}

操作系统课的实验(银行家算法)#include "malloc.h"   #include "stdio.h"   #include "stdlib.h"   #define alloclen sizeof(struct allocation)   #define maxlen sizeof(struct max)   #define avalen sizeof(struct available)   #define needlen sizeof(struct need)   #define finilen sizeof(struct finish)   #define pathlen sizeof(struct path)   struct allocation   {   int value;   struct allocation *next;   };   struct max   {   int value;   struct max *next;   };   struct available /*可用资源数*/   {   int value;   struct available *next;   };   struct need /*需求资源数*/   {   int value;   struct need *next;   };   struct path   {   int value;   struct path *next;   };   struct finish   {   int stat;   struct finish *next;   };   int main()   {   int row,colum,status=0,i,j,t,temp,processtest;   struct allocation *allochead,*alloc1,*alloc2,*alloctemp;   struct max *maxhead,*maxium1,*maxium2,*maxtemp;   struct available *avahead,*available1,*available2,*workhead,*work1,*work2,*worktemp,*worktemp1;   struct need *needhead,*need1,*need2,*needtemp;   struct finish *finihead,*finish1,*finish2,*finishtemp;   struct path *pathhead,*path1,*path2;   printf("\n请输入系统资源的种类数:");   scanf("%d",&colum);   printf("请输入现时内存中的进程数:");   scanf("%d",&row);   printf("请输入已分配资源矩阵:\n");   for(i=0;i<row;i++)   {   for (j=0;jnext=alloc2->next=NULL;   scanf("%d",&allochead->value);   status++;   }   else   {   alloc2=(struct allocation *)malloc(alloclen);   scanf("%d,%d",&alloc2->value);   if(status==1)   {   allochead->next=alloc2;   status++;   }   alloc1->next=alloc2;   alloc1=alloc2;   }   }   }   alloc2->next=NULL;   status=0;   printf("请输入最大需求矩阵:\n");   for(i=0;i<row;i++)   {   for (j=0;jnext=maxium2->next=NULL;   scanf("%d",&maxium1->value);   status++;   }   else   {   maxium2=(struct max *)malloc(maxlen);   scanf("%d,%d",&maxium2->value);   if(status==1)   {   maxhead->next=maxium2;   status++;   }   maxium1->next=maxium2;   maxium1=maxium2;   }   }   }   maxium2->next=NULL;   status=0;   printf("请输入现时系统剩余的资源矩阵:\n");   for (j=0;jnext=available2->next=NULL;   work1->next=work2->next=NULL;   scanf("%d",&available1->value);   work1->value=available1->value;   status++;   }   else   {   available2=(struct available*)malloc(avalen);   work2=(struct available*)malloc(avalen);   scanf("%d,%d",&available2->value);   work2->value=available2->value;   if(status==1)   {   avahead->next=available2;   workhead->next=work2;   status++;   }   available1->next=available2;   available1=available2;   work1->next=work2;   work1=work2;   }   }   available2->next=NULL;   work2->next=NULL;   status=0;   alloctemp=allochead;   maxtemp=maxhead;   for(i=0;i<row;i++)   for (j=0;jnext=need2->next=NULL;   need1->value=maxtemp->value-alloctemp->value;   status++;   }   else   {   need2=(struct need *)malloc(needlen);   need2->value=(maxtemp->value)-(alloctemp->value);   if(status==1)   {   needhead->next=need2;   status++;   }   need1->next=need2;   need1=need2;   }   maxtemp=maxtemp->next;   alloctemp=alloctemp->next;   }   need2->next=NULL;   status=0;   for(i=0;inext=finish2->next=NULL;   finish1->stat=0;   status++;   }   else   {   finish2=(struct finish*)malloc(finilen);   finish2->stat=0;   if(status==1)   {   finihead->next=finish2;   status++;   }   finish1->next=finish2;   finish1=finish2;   }   }   finish2->next=NULL; /*Initialization compleated*/   status=0;   processtest=0;   for(temp=0;temp<row;temp++)   {   alloctemp=allochead;   needtemp=needhead;   finishtemp=finihead;   worktemp=workhead;   for(i=0;istat==0)   {   for(j=0;jnext,worktemp=worktemp->next)   if(needtemp->valuevalue)   processtest++;   if(processtest==colum)   {   for(j=0;jvalue+=alloctemp->value;   worktemp1=worktemp1->next;   alloctemp=alloctemp->next;   }   if(status==0)   {   pathhead=path1=path2=(struct path*)malloc(pathlen);   path1->next=path2->next=NULL;   path1->value=i;   status++;   }   else   {   path2=(struct path*)malloc(pathlen);   path2->value=i;   if(status==1)   {   pathhead->next=path2;   status++;   }   path1->next=path2;   path1=path2;   }   finishtemp->stat=1;   }   else   {   for(t=0;tnext;   finishtemp->stat=0;   }   }   else   for(t=0;tnext;   alloctemp=alloctemp->next;   }   processtest=0;   worktemp=workhead;   finishtemp=finishtemp->next;   }   }   path2->next=NULL;   finishtemp=finihead;   for(temp=0;tempstat==0)   {   printf("\n系统处于非安全状态!\n");   exit(0);   }   finishtemp=finishtemp->next;   }   printf("\n系统处于安全状态.\n");   printf("\n安全序列为: \n");   do   {   printf("p%d ",pathhead->value);   }   while(pathhead=pathhead->next);   printf("\n");   return 0;   } #include "string.h" #include #include #define M 5 #define N 3 #define FALSE 0 #define TRUE 1 /*M个进程对N类资源最大资源需求量*/ int MAX[M][N]={{7,5,3},{3,2,2},{9,0,2},{2,2,2},{4,3,3}}; /*系统可用资源数*/ int AVAILABLE[N]={10,5,7}; /*M个进程对N类资源最大资源需求量*/ int ALLOCATION[M][N]={{0,0,0},{0,0,0},{0,0,0},{0,0,0},{0,0,0}}; /*M个进程已经得到N类资源的资源量 */ int NEED[M][N]={{7,5,3},{3,2,2},{9,0,2},{2,2,2},{4,3,3}}; /*M个进程还需要N类资源的资源量*/ int Request[N]={0,0,0}; void main() { int i=0,j=0; char flag='Y'; void showdata(); void changdata(int); void rstordata(int); int chkerr(int); showdata(); while(flag=='Y'||flag=='y') { i=-1; while(i=M) { printf("请输入需申请资源的进程号(从0到"); printf("%d",M-1); printf(",否则重输入!):"); scanf("%d",&i); if(i=M)printf("输入的进程号不存在,重新输入!\n"); } printf("请输入进程"); printf("%d",i); printf("申请的资源数\n"); for (j=0;jNEED[i][j]) { printf("进程"); printf("%d",i); printf("申请的资源数大于进程"); printf("%d",i); printf("还需要"); printf("%d",j); printf("类资源的资源量!申请不合理,出错!请重新选择!\n"); /*printf("申请不合理,出错!请重新选择!\n");*/ flag='N'; break; } else { if(Request[j]>AVAILABLE[j]) { printf("进程"); printf("%d",i); printf("申请的资源数大于系统可用"); printf("%d",j); printf("类资源的资源量!申请不合理,出错!请重新选择!\n"); /*printf("申请不合理,出错!请重新选择!\n");*/ flag='N'; break; } } } if(flag=='Y'||flag=='y') { changdata(i); if(chkerr(i)) { rstordata(i); showdata(); } else showdata(); } else showdata(); printf("\n"); printf("是否继续银行家算法演示,按'Y'或'y'键继续,按'N'或'n'键退出演示: "); scanf("%c",&flag); } } void showdata() { int i,j; printf("系统可用的资源数为:\n"); printf(" "); for (j=0;j<N;j++){ printf(" 资源"); printf("%d",j); printf(":"); printf("%d",AVAILABLE[j]); /*printf("\n");*/ /* cout<<endl; // cout<<"各进程资源的最大需求量:"<<endl<<endl; // for (i=0;i<M;i++) // { // cout<<"进程"<<i<<":"; // for (j=0;j<N;j++)cout<<" 资源"<<j<<": "<<MAX[i][j]; // cout<<endl; */ } printf("\n"); printf("各进程还需要的资源量:\n"); for (i=0;i<M;i++) { printf(" 进程"); printf("%d",i); printf(":"); for (j=0;j<N;j++){ printf("资源"); printf("%d",j); printf(":"); printf("%d",NEED[i][j]); /*printf("\n");*/ } printf("\n"); } printf("各进程已经得到的资源量: \n"); for (i=0;i<M;i++) { printf(" 进程"); printf("%d",i); /*printf(":\n");*/ for (j=0;j<N;j++){ printf("资源"); printf("%d",j); printf(":"); printf("%d",ALLOCATION[i][j]); /*printf("\n");*/ } printf("\n"); } } void changdata(int k) { int j; for (j=0;j<N;j++) { AVAILABLE[j]=AVAILABLE[j]-Request[j]; ALLOCATION[k][j]=ALLOCATION[k][j]+Request[j]; NEED[k][j]=NEED[k][j]-Request[j]; } }; void rstordata(int k) { int j; for (j=0;j<N;j++) { AVAILABLE[j]=AVAILABLE[j]+Request[j]; ALLOCATION[k][j]=ALLOCATION[k][j]-Request[j]; NEED[k][j]=NEED[k][j]+Request[j]; } }; int chkerr(int s) { int WORK,FINISH[M],temp[M]; int i,j,k=0; for(i=0;i<M;i++)FINISH[i]=FALSE; for(j=0;j<N;j++) { WORK=AVAILABLE[j]; i=s; while(i<M) { if (FINISH[i]==FALSE&&NEED[i][j]<=WORK) { WORK=WORK+ALLOCATION[i][j]; FINISH[i]=TRUE; temp[k]=i; k++; i=0; } else { i++; } } for(i=0;i<M;i++) if(FINISH[i]==FALSE) { printf("\n"); printf("系统不安全!!! 本次资源申请不成功!!!\n"); printf("\n"); return 1; } } printf("\n"); printf("经安全性检查,系统安全,本次分配成功。\n"); printf("\n"); printf(" 本次安全序列:"); for(i=0;i"); } printf("\n"); return 0; }
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值